java - 在 Hashmap 中重新散列
全部标签 为了便于创作,我这样写我的散列:h={:key1:[:val1,:val2,:val3],:key2:[:val4,:val5,:val6]}但无论我在哪里使用它,我都需要查找与值关联的键。目前我正在做以下事情来改造它:h=Hash[*{:key1:[:val1,:val2,:val3],:key2:[:val4,:val5,:val6]}.map{|key,vals|vals.map{|val|[val,key]}}.flatten]这给了我想要的:{:val1=>:key1,:val2=>key1,:val3=>key1,:val4=>key2,:val5=>:key2,:val6
这只是一个假设性的问题,如果您没有Array和Hash类,是否有任何方法可以在纯Ruby中实现Array类?怎么办? 最佳答案 是的,我们可以!classMyArrayincludeEnumerabledefinitialize@size=0enddef[1,2]这通过在对象上创建实例变量@a0、@a1等来表示数组索引0、1等来工作。它具有恒定的时间长度和索引操作。其余的操作(删除等)需要付出更多的努力才能实现,但这是绝对可行的。请注意,索引操作的常量时间属性取决于底层Ruby运行时为实例变量使用适当的数据结构。
我没有使用ruby1.8.7,最近我很惊讶:{:k=>30}.to_s#=>"k30"是否准备好使用fix将哈希转换为ruby1.8.7的字符串以使其看起来像:{:k=>30}.to_s#=>"{:k=>30}" 最佳答案 hash.to_s确实已从1.8.7更改为1.9.3。在1.8.7中,(引用:http://ruby-doc.org/core-1.8.7/Hash.html#method-i-to_s):Convertshshtoastringbyconvertingthehashtoanarrayof[key,val
我的问题与这篇文章中提出的问题相同,但针对的是Ruby而不是Perl。Comparing-two-hashes-with-the-keys-and-values-Perl我想比较两个散列,首先看看第一个散列中的键是否存在于第二个散列中,如果存在,则比较值并打印散列键的值,否则如果值不相等,打印具有不相等值的键。我看了很多建议,但找不到比较两个不同哈希中的值的答案。 最佳答案 h1={"a"=>1,"b"=>2,"c"=>3}h2={"a"=>2,"b"=>2,"d"=>3}(h1.keys&h2.keys).each{|k|puts
如何使用已有值的键在Hash对象中追加一个值。例如如果我有>>my_hash=Hash.new>>my_hash[:my_key]="Value1"#thenappendavalue,letssay"Value2"tomyhash,usingthatsamekey"my_key"#sothatitcanbe>>my_hash[:my_key]=>["Value1","Value2"]我知道编写自己的方法很容易,但我只是想知道是否有内置方法。 最佳答案 我不知道我是否没有理解您的观点,但您是否考虑过以下问题:1.9.3(main):0
我在Windows上使用带有DevKit的Ruby1.9.3(在Win764位上都是32位)。现在我尝试安装rails,但从bundle中得到一个错误。如果我尝试运行(包在提示什么)geminstalljson我收到以下错误消息:D:\RubyTest>geminstalljsonTemporarilyenhancingPATHtoincludeDevKit...Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingjson:ERROR:Failedtobuildgemnativeextension.D:
我正在尝试格式化{"key"=>"value"}以将其转换为:{"key":"value"}用于写入json文件。现在我正在做:hash={"key"=>"value"}putshash.to_json.gsub('{','{\n\t')开始。这输出{\n\t"key":"value"}为什么我不能换行? 最佳答案 为漂亮的东西欢呼,为避免正则表达式欢呼!使用内置的JSON.pretty_generate方法require'json'putsJSON.pretty_generatehash,options耶!选项如下:indent:
我有一个像这样的散列h={1=>{"inner"=>45},2=>{"inner"=>46},"inner"=>47}如何删除包含键“inner”的每一对?你可以看到一些“内部”对直接出现在h中,而另一些成对出现在h中请注意,我只想删除“内部”对,因此如果我对上述哈希调用我的批量删除方法,我应该得到h={1=>{},2=>{}}因为这些对没有键=="inner" 最佳答案 真的,这就是拒绝!用于:deff!xx.reject!{|k,v|'inner'==k}ifx.is_a?Hashx.each{|k,v|f!x[k]}end
我需要一个散列,其键的默认值应为0。(基本上我正在制作一个计数器)。key未知,所以我无法在开始时初始化它们。同样,每次出现该键时,该值都应增加1。我想出了这个:hash={}hash[key]?hash[key]+=1:hash[key]=0这看起来不错而且简短,但我不喜欢在一行代码中重复多次hash[key]。有没有更好的写法? 最佳答案 我想你只需要给散列一个默认值0hash=Hash.new(0)然后对于每次出现的键,你不需要检查它的值,直接增加它:hash[key]+=1引用:Hash#new.
假设我们有一个散列:flash={}flash[:error]="Thisisanerror."flash[:info]="Thisisaninformation."我想把它转换成一个字符串:"Thisisanerror.Thisisaninformation".在一个漂亮的衬里;)我发现了类似的东西:flash.to_a.collect{|item|"#{item[1]}"}.join这解决了我的问题,但也许哈希表类中内置了更好的解决方案? 最佳答案 Hash包括Enumerable,所以你可以使用collect:flash.co